var prefix = "/sys/user"

$(function() {
	var deptId = '';
	getTreeData();
	load(deptId);
});
showButton('#user');
function load(deptId) {
	$('#exampleTable')
		.bootstrapTable(
			{
				method : 'POST', // 服务器数据的请求方式 get or post
				url : window.API_SERVER_URL + 'sys/user/list', // 服务器数据的加载地址
				// showRefresh : true,
				// showToggle : true,
				// showColumns : true,
				iconSize : 'outline',
				toolbar : '#exampleToolbar',
				striped : true, // 设置为true会有隔行变色效果
				dataType : "json", // 服务器返回的数据类型
				pagination : true, // 设置为true会在底部显示分页条
				// queryParamsType : "limit",
				// //设置为limit则会发送符合RESTFull格式的参数
				singleSelect : false, // 设置为true将禁止多选
				// contentType : "application/x-www-form-urlencoded",
				// //发送到服务器的数据编码类型
				pageSize : 10, // 如果设置了分页，每页数据条数
				pageNumber : 1, // 如果设置了分布，首页页码
				// search : true, // 是否显示搜索框
				showColumns : false, // 是否显示内容下拉框（选择显示的列）
				sidePagination : "server", // 设置在哪里进行分页，可选值为"client" 或者
				// "server"
				queryParams : function(params) {
					// console.log(params.limit)
					var paramsJSON = {
						// 说明：传入后台的参数包括offset开始索引，limit步长，sort排序列，order：desc或者,
						// 以及所有列的键值对
						limit : params.limit,
						// console.log(params.limit)
						offset : params.offset,
						name : $('#searchName').val(),
						deptId : $('#deptid').val()
					};
					// console.log(paramsJSON);

					return JSON.stringify(paramsJSON);

				},
				// //请求服务器数据时，你可以通过重写参数的方式添加一些额外的参数，例如 toolbar 中的参数 如果
				// queryParamsType = 'limit' ,返回参数必须包含
				// limit, offset, search, sort, order 否则, 需要包含:
				// pageSize, pageNumber, searchText, sortName,
				// sortOrder.
				// 返回false将会终止请求
				columns : [
					{
						checkbox : true
					},
					{
						field : 'name',
						title : '姓名'
					},
					{
						field : 'username',
						title : '用户名'
					},
					{
                    	field : 'mobile',
                        title : '手机'
                    },
                    {
                        field : 'email',
                        title : '邮箱'
                    },
					{
						field : 'status',
						title : '状态',
						align : 'center',
						formatter : function(value, row, index) {
							if (value == '0') {
								return '<span class="label label-danger">禁用</span>';
							} else if (value == '1') {
								return '<span class="label label-primary">正常</span>';
							}
						}
					},
					{
						title : '操作',
						field : 'id',
						align : 'center',
						formatter : function(value, row, index) {
							var e = '<a  class="btn warning btn-sm ' + s_edit_h + '" href="javascript:void(0);"  title="编辑" onclick="edit(\''
								+ row.userId
								+ '\')"><img src= "'+SERVER_URL+'static/img/edit.png"></a> ';
							var d = '<a class="btn warning btn-sm ' + s_remove_h + '" href="javascript:void(0);" title="删除"   onclick="remove(\''
								+ row.userId
								+ '\')"><img src= "'+SERVER_URL+'static/img/remove.png"></a> ';
							var f = '<a class="btn warning btn-sm ' + s_resetPwd_h + '" href="javascript:void(0);" title="重置密码"   onclick="resetPwd(\''
								+ row.userId
								+ '\')"><img src= "'+SERVER_URL+'static/img/reset.png"></a> ';
								 var permissionsArr = JSON.parse(localStorage.getItem("permissions"));
							 if(permissionsArr.indexOf('sys:user:edit') == -1){
						    	e = '';
						   }
						
						   if(permissionsArr.indexOf('sys:user:remove') == -1){
						  		d = '';
						   }
						
						   if(permissionsArr.indexOf('sys:user:resetPwd') == -1){
						  		f = '';
						   }
							return e+d+f;
						}
					} ]
			});
}
function reLoad() {
	$('#exampleTable').bootstrapTable('refresh');
}

//新增
function add() {
	if($('#deptid').val()==''){
		layer.msg("请先选择部门");
		return;
	}
	// iframe层
	layer.open({
		type : 2,
		title : '增加用户',
		maxmin : true,
		shadeClose : false, // 点击遮罩关闭层
		area : [ '800px', '520px' ],
	  // content : prefix + '/add'
		content : "../../../templates/system/user/add.html",
		success: function(layero, index){
             var body = layer.getChildFrame('body',index);//建立父子联系
             $(body).find('input[id=deptId]').val($('#deptid').val());
             $(body).find('input[id=deptName]').val($('#deptName').val());
         }
	});
}
function remove(id) {
	layer.confirm('确定要删除选中的记录？', {
		btn : [ '确定', '取消' ]
	}, function() {
		$.ajax({
			headers:{"Authorization":token},
			url : ip + "sys/user/remove",
			type : "post",
			data : {
				'id' : id
			},
			success : function(r) {
				if (r.code == 0) {
					layer.msg(r.msg);
					reLoad();
				} else {
					layer.msg(r.msg);
				}
			}
		});
	})
}
function edit(id) {
	 var _this = $(this),
        data =_this.parent().siblings(),
        arr = id;
	layer.open({
		type : 2,
		title : '用户修改',
		maxmin : true,
		shadeClose : false,
		area : [ '800px', '520px' ],
			content : '../../../templates/system/user/edit.html',
			success: function(layero, index){
	             $.ajax({
            			type : 'get',
                     	headers:window.getRequestHears(true),
            			url : ip + 'sys/user/getById/'+id,
            			success : function(r) {
            				parentId = r.parentId;
            				name = r.name;
            				orderNum = r.orderNum;
            				delFlag = r.delFlag;
            				var body = layer.getChildFrame('body',index);//建立父子联系
                            var iframeWin = window[layero.find('iframe')[0]['name']];
							$(body).find('input[id=userId]').val(r.userId);
							$(body).find('input[id=userRoleIds]').val(r.roleIds);
							$(body).find('input[id=name]').val(r.name);
							$(body).find('input[id=username]').val(r.username);
							$(body).find('input[id=deptId]').val(r.deptId);
							$(body).find('input[id=deptName]').val(r.deptName);
							$(body).find('input[id=email]').val(r.email);
							$(body).find('input[id=mobile]').val(r.mobile);
							$(body).find('input[name="status"][value="'+r.status+'"]').attr("checked",'checked');
							if(r.userAreaList){
								var areaIds = '';
								var areaNames = '';
								$.each(r.userAreaList,function (i,userArea) {
									if(i>0){
                                        areaIds += ',';
                                        areaNames += ',';
									}
                                    areaIds += userArea.areaId;
                                    areaNames += userArea.areaName;
                                });

                                $(body).find('input[id=areaIds]').val(areaIds);
                                $(body).find('input[id=areaNames]').val(areaNames);
							}
                            iframeWin.initForm();
            			}
            		});
                 }
			
	});
}
function resetPwd(id) {
	layer.open({
		type : 2,
		title : '重置密码',
		maxmin : true,
		shadeClose : false, // 点击遮罩关闭层
		area : [ '400px', '260px' ],
		content : '../../../templates/system/user/reset_pwd.html' // iframe的url
	});
}
function batchRemove() {
	var rows = $('#exampleTable').bootstrapTable('getSelections'); // 返回所有选择的行，当没有选择的记录时，返回一个空数组
	if (rows.length == 0) {
		layer.msg("请选择要删除的数据");
		return;
	}
	layer.confirm("确认要删除选中的'" + rows.length + "'条数据吗?", {
		btn : [ '确定', '取消' ]
	// 按钮
	}, function() {
		var ids = new Array();
		// 遍历所有选择的行数据，取每条数据对应的ID
		$.each(rows, function(i, row) {
			ids[i] = row['userId'];
		});
		$.ajax({
			type : 'POST',
			 headers:{"JwtAuthorization":JwtAuthorizations,"Authorization":token},
			data : {
				userIds : ids
			},
			url : ip + 'sys/user/batchRemove',
			success : function(r) {
				if (r.code == 0) {
					layer.msg(r.msg);
					reLoad();
				} else {
					layer.msg(r.msg);
				}
			}
		});
	}, function() {});
}
function getTreeData() {
	$.ajax({
		type : "GET",
		url :ip + "system/sysDept/tree",
		success : function(tree) {
			loadTree(tree);
		}
	});
}
function loadTree(tree) {
	$('#jstree').jstree({
		'core' : {
			'data' : tree
		},
		"plugins" : [ "search" ]
	});
	$('#jstree').jstree().open_all();
}
$('#jstree').on("changed.jstree", function(e, data) {
	if (data.selected == -1) {
		var opt = {
			query : {
				deptId : '',
			}
		}
		
		$('#deptid').val('');
		$('#exampleTable').bootstrapTable('refresh', opt);
	} else {
		var opt = {
			query : {
				deptId : data.selected[0],
			}
		}
		$('#deptid').val(data.selected[0]);
		$('#deptName').val(data.node.text);
		$('#exampleTable').bootstrapTable('refresh',opt);
	}

});
